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(54) Point-to-point communication using e-mail to establish dynamic network addresses 



(57) In a computer system having an audio trans- 
ducer and a display device and being operatively cou- 
pled to other computers over a computer network (24), 
such as the Internet, means are included for establish- 
ing a point-to-point communication link between proc- 
esses. The means provide for transmitting from a first 
processing unit (12) to the Internet an E-mail signal, in- 



cluding a first IP address assigned to the first processing 
unit, and for processing the E-mail signal through the 
Internetto deliverthe E-mail signal to a second process- 
ing unit (22). Further means are provided for transmit- 
ting a second IP address to the first processing unit for 
establishing a point-to-point communication link be- 
tween the first and second processing units through the 
Internet. 
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Description 

FIELD OF THE INVENTION 

[0001 ] The present invention relates in general to data 5 
processing systems, and more specifically, to an appa- 
ratus, a method and a computer program product for fa- 
cilitating audio communications over computer net- 
works. 

BACKGROUND OF THE INVENTION 

[0002] The increased popularity of on-line services 
such as AMERICA ONLINE (TM), COMPUSERVE (R), 
and other services such as Internet gateways have 
spurred applications to provide multimedia contents, in- 
cluding video and voice clips, to online users. An exam- 
ple of an online voice clip application is VOICE E-MAIL 
FOR WINCIM and VOICE E-MAIL FOR AMERICA ON- 
LINE (TM), available from Bonzi Software, as described 
in "Simple Utilities Send Voice E-Mail Online", MULTI- 
MEDIA WORLD, VOL 2, NO. 9, August 1995, p. 52. 
Using such Voice E-Mail software, a user may create an 
audio message to be sent to a predetermined E-mail ad- 
dress specified by the user. 

[0003] Generally, devices interfacing with the Internet 
and other online services may communicate with each 
other upon establishing respective device addresses. 
One type of device address is the Internet Protocol (IP) 
address, which acts as a pointer to the device associat- 
ed with the IP address. A typical device may have a Se- 
rial Line Internet Protocol or Point-to-Point Protocol 
(SLIP/PPP) account with a permanent IP address for re- 
ceiving E-mail, voicemail, and the like over the Internet. 
E-mail and voicemail is generally intended to convey 
text, audio, etc., with any routing information such as an 
IP address and routing headers generally being consid- 
ered an artifact of the communication, or even gibberish 
to the recipient. 

[0004] Devices such as a host computer or server of 
a company may include multiple modems for connection 
of users to the Internet, with a temporary IP address al- 
located to each user. For example, the host computer 
may have a general IP address "XXX. XXX. XXX", and 
each user may be allocated a successive IP address of 
XXX.XXX.XXX.10, XXX.XXX.XXX.11, xxx.xxx.xxx. 
12, etc. Such temporary IP addresses may be reas- 
signed or recycled to the users, for example, as each 
user is successively connected to an outside party. For 
example, a host computer of a company may support a 
maximum of 254 IP addresses which are pooled and 
shared between devices connected to the host compu- 
ter. 

[0005] Permanent I P addresses of users and devices 
accessing the Internet readily support point-to-point 
communications of voice and video signals over the In- 
ternet. For example, global real-time video conferencing 
has been implemented using dedicated IP addresses 



and mechanisms known as reflectors. 
[0006] A technique for matching domain names to In- 
ternet Protocol addresses is described in the text enti- 
tled "Internetworking With TCP/IP", 2nd Edition, by 
Douglas E. Comer, November 1992, Prentice Hall, En- 
glewood Cliffs, New Jersey, U.S.A. Comer describes a 
domain name system and cooperative systems of name 
servers for matching domain names to network ad- 
dresses. Each name server is a server program that 
supplies mapping of domain names to IP addresses. 
The system described in Comer, however, is not de- 
signed for use with network nodes whose network 
names or name to address bindings change frequently. 
[0007] International Publication WO 92/19054 dis- 
closes a network monitoring system including an ad- 
dress tracking module which uses passive monitoring 
of all packet communications over a local area network 
to maintain a name table of IP address mappings. The 
disclosed address tracking module is capable of moni- 
toring only a small number of nodes on a local area net- 
work and is not suitable for use with a multitude of nodes 
over a wide area network. 

[0008] Due to the dynamic nature of temporary IP ad- 
dresses of some devices accessing the Internet, point- 
to-point communications in real-time of voice and video 
have been generally difficult to attain. 

SUMMARY OF THE INVENTION 

[0009] In a system for enabling point-to-point commu- 
nications between a plurality of processing units over 
the Internet, means are provided for establishing a 
point-to-point communication link between a first 
processing unit and a second processing unit. The in- 
vention, as defined in the claims, comprises (a) means 
for transmitting from a first processing unit to the Internet 
an E-mail signal, including a first IP address assigned 
to the first processing unit, (b) means for processing the 
E-mail signal through the Internet to deliver the E-mail 
signal to a second processing unit and (c) means for 
transmitting a second IP address to the first processing 
unit for establishing a point-to-point communication link 
between the first and second processing units through 
the Internet. 

[001 0] The invention is in particular suitable for being 
used in connection with computer networks, such as the 
Internet, wherein the processing unit does not have a 
fixed or predetermined network protocol address. The 
invention thus provides for a protocol wherein a calling 
processing unit transmits by E-mail its dynamically as- 
signed network protocol address, or IP address, directly 
to the called processing unit. The called processing unit 
then transmits its dynamically assigned IP address to 
the calling processing unit also via E-mail message. 

BRIEF DESCRIPTION OF THE DRAWINGS 

[001 1 ] The features of the invention wilt become more 
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readily apparent and may be better understood by re- 
ferring to the following detailed description of an illustra- 
tive embodiment of the present invention, taken in con- 
junction with the accompanying drawings, in which: 

FIG. 1 illustrates, in block diagram format, a system 
for the disclosed point-to-point Internet protocol; 
FIG. 2 illustrates, in block diagram format, the sys- 
tem using a secondary point-to-point Internet pro- 
tocol; 

FIG. 3 illustrates, in block diagram format, the sys- 
tem of FIGS. 1 -2 with the point-to-point Internet pro- 
tocol established; 

FIG. 4 is another block diagram of the system of 
FIGS 1-2 with audio communications being con- 
ducted; 

FIG. 5 illustrates a display screen for a processing 
unit; 

FIG. 6 illustrates another display screen for a 
processing unit; 

FIG. 7 illustrates a flowchart of the initiation of the 
point-to-point Internet protocols; 
FIG. 8 illustrates a flowchart of the performance of 
the primary point-to-point Internet protocols; and 
FIG. 9 illustrates a flowchart of the performance of 
the secondary point-to-point Internet protocol. 

DETAILED DESCRIPTION 

[0012] Referring now in specific detail to the drawings, 
with like reference numerals identifying similar or iden- 
tical elements, as shown in FIG. 1 , the present disclo- 
sure describes a point-to-point network protocol and 
system 10 for using such a protocol. 
[0013] In an exemplary embodiment, the system 10 
includes a first processing unit 12 for sending at least a 
voice signal from a first user to a second user. The first 
processing unit 12 includes a processor 14, a memory 
16, an input device 18, and an output device 20. The 
output device 20 includes at least one modem capable 
of, for example, 14.4 kbaud communications and oper- 
atively connected via wired and/or wireless communi- 
cation connections to the Internet or other computer net- 
works such as an Intranet, i.e., a private computer net- 
work. One skilled in the art would understand that the 
input device 18 may be implemented at least in part by 
the modem of the output device 20 to allow input signals 
from the communication connections to be received. 
The second processing unit 22 may have a processor, 
memory, and input and output devices, including at least 
one modem and associated communication connec- 
tions, as described above for the first processing unit 
12. In an exemplary embodiment, each of the process- 
ing units 12, 22 may execute the WEBPHONE™ Inter- 
net telephony application available from NetSpeak Cor- 
poration, Boca Raton, FL t which is capable of perform- 
ing the disclosed point-to-point Internet protocol and 
system 10, as described herein. 



[0014] The first processing unit 12 and the second 
processing unit 22 are operatively connected to the In- 
ternet 24 by communication devices and software 
known in the art, such as an Internet Service Provider 
(ISP) or an Internet gateway. The processing units 12, 
22 may be operatively interconnected through the Inter- 
net 24 to a connection server 26, and may also be op- 
eratively connected to a mail server 28 associated with 
the Internet 24. 

[0015] The connection server 26 includes a processor 
30, a timer 32 for generating time stamps, and a memory 
such as a database 34 for storing, for example, E-mail 
and Internet Protocol (IP) addresses of logged-in units. 
In an exemplary embodiment, the connection server 26 
may be a SPARC 5 server or a SPARC 20 server, avail- 
able from SUN MICROSYSTEMS, INC., Mountain View, 
CA, having a central processing unit (CPU) as proces- 
sor 30, an operating system (OS) such as UNIX, for pro- 
viding timing operations such as maintaining the timer 
32, a hard drive or fixed drive, as well as dynamic ran- 
dom access memory (DRAM) for storing the database 
34, and a keyboard and display and/or other input and 
output devices (not shown in FIG. 1). The database 34 
may be an SQL database available from ORACLE or 
INFORMIX. 

[0016] In an exemplary embodiment, the mail server 
28 may be a Post Office Protocol (POP) Version 3 mail 
server including a processor, memory, and stored pro- 
grams operating in a UNIX environment, or, alternative- 
ly, another OS, to process E-mail capabilities between 
processing units and devices over the Internet 24. 
[0017] The first processing unit 12 may operate the 
disclosed point-to-point Internet protocol by a computer 
program described hereinbelow in conjunction with FIG. 
6, which may be implemented from compiled and /or in- 
terpreted source code in the C++ programming lan- 
guage and which may be downloaded to the first 
processing unit 12 from an external computer. The op- 
erating computer program may be stored in the memory 
16, which may include about 8 MB RAM and/or a hard 
or fixed drive having about 8 MB. Alternatively, the 
source code may be implemented in the first processing 
unit 12 as firmware, as an erasable read only memory 
(EPROM), etc. It is understood that one skilled in the art 
would be able to use programming languages other than 
C++ to implement the disclosed point-to-point network 
protocol and system 1 0. 

[0018] The processor 14 receives input commands 
and data from a first user associated with the first 
processing unit 12 though the input device 18, which 
may be an input port connected by a wired, optical, or 
a wireless connection for electromagnetic transmis- 
sions, or alternatively may be transferable storage me- 
dia, such as floppy disks, magnetic tapes, compact 
disks, or other storage media including the input data 
from the first user. 

[0019] The input device 18 may include a user inter- 
face (not shown) having, for example, at least one but- 
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ton actuated by the user to input commands to select 
from a plurality of operating modes to operate the first 
processing unit 12. In alternative embodiments, the in- 
put device 1 8 may include a keyboard, a mouse, a touch 
screen, and/or a data reading device such as a disk 
drive for receiving the input data from input data files 
stored in storage media such as a floppy disk or, for ex- 
ample, an 8 mm storage tape. The input device 1 8 may 
alternatively include connections to other computer sys- 
tems to receive the input commands and data there- 
from. 

[0020] The first processing unit 1 2 may include a vis- 
ual interface for use in conjunction with the input device 
18 and output device 20 similar to those screens illus- 
trated in FIGS, 5-6, discussed below. It is also under- 
stood that alternative devices may be used to receive 
commands and data from the user, such as keyboards, 
mouse devices, and graphical user interfaces (GUI) 
such as WINDOWS™ 3,1 available form MICROSOFT 
Corporation, Redmond, WA. ( and other operating sys- 
tems and GUIs, such as OS/2 and OS/2 WARP, availa- 
ble from IBM CORPORATION, Boca Raton, FL 
Processing unit 12 may also include microphones and/ 
or telephone handsets for receiving audio voice data 
and commands, speech or voice recognition devices, 
dual tone multifrequency (DTMF) based devices, and/ 
or software known in the art to accept voice data and 
commands and to operate the first processing unit 12. 
[0021] In addition, either of the first processing unit 12 
and the second processing unit 22 may be implemented 
in a personal digital assistant (PDA) providing modem 
and E-mail capabilities and Internet access, with the 
PDA providing the input/output screens for mouse inter- 
actions or for touchscreen activation as shown, for ex- 
ample, in FIGS. 5-6, as a combination of the input device 
1 8 and output device 20. 

[0022] For clarity of explanation, the illustrative em- 
bodiment of the disclosed point-to-point Internet proto- 
col and system 10 is presented as having individual 
functional blocks, which may include functional blocks 
labeled as "processor" and "processing unit". The func- 
tions represented by these blocks may be provided 
through the use of either shared or dedicated hardware, 
including, but not limited to, hardware capable of exe- 
cuting software. For example, the functions of each of 
the processors and processing units presented herein 
may be provided by a shared processor or by a plurality 
of individual processors. Moreover, the use of the func- 
tional blocks with accompanying labels herein is not to 
be construed to refer exclusively to hardware capable 
of executing software. Illustrative embodiments may in- 
clude digital signal processor (DSP) hardware, such as 
the AT&T DSP 1 6 or DSP32C, read-only memory (ROM) 
for storing software performing the operations dis- 
cussed below, and random access memory (RAM) for 
storing DSP results. Very large scale integration (VLSI) 
hardware embodiments, as well as custom VLSI circuit- 
ry in combination with a general purpose DSP circuit, 



may also be provided. Any and all of these embodiments 
may be deemed to fail within the meaning of the labels 
for the functional blocks as used herein. 
[0023] The processing units 12, 22 are capable of 
5 placing calls and connecting to other processing units 
connected to the Internet 24, for example, via dialup 
SLIP/PPP lines. In an exemplary embodiment, each 
processing unit assigns an unsigned long session 
number, for example, a 32- bit long sequence in a *.ini 
10 file for each call. Each call may be assigned a succes- 
sive session number in sequence, which may be used 
by the respective processing unit to associate the call 
with one of the SLIP/PPP lines, to associate a <Connec- 
tOK> response signal with a <Connect Request> signal, 
15 and to allow for multiplexing and demultiplexing of in- 
bound and outbound conversations on conference 
lines, as explained hereinafter. 
[0024] For callee (or called) processing units with 
fixed I P addresses, the caller (or calling) processing unit 
20 may open a "socket", i.e. a file handle or address indi- 
cating where data is to be sent, and transmit a <Call> 
command to establish communication with the callee 
utilizing, for example, datagram services such as Inter- 
net Standard network layering as well as transport lay- 
25 ering, which may include a Transport Control Protocol 
(TCP) or a User Datagram Protocol (UDP) on top of the 
IP. Typically, a processing unit having a fixed IP address 
may maintain at least one open socket and a called 
processing unit waits for a <Call> command to assign 
30 the open socket to the incoming signal. If all lines are in 
use, the callee processing unit sends a BUSY signal or 
message to the callee processing unit. As shown in FIG. 
1 , the disclosed point-to-point Internet protocol and sys- 
tem 10 operate when a callee processing unit does not 
35 have a fixed or predetermined IP address. In the exem- 
plary embodiment and without loss of generality, the first 
processing unit 12 is the caller processing unit and the 
second processing unit 22 is the called processing unit. 
When either of processing units 12, 22 logs on to the 
40 internet via a dial-up connection, the respective unit is 
provided a dynamically allocated IP address by the a 
connection service provider. 

[0025] Upon the first user initiating the point-to-point 
Internet protocol when the first user is logged on to the 
45 Internet 24, the first processing unit 12 automatically 
transmits its associated E-mail address and its dynam- 
ically allocated IP address to the connection server 26. 
The connection server 26 then stores these addresses 
in the database 34 and time stamps the stored address- 
so es using timer 32. The first user operating the first 
processing unit 12 is thus established in the database 
34 as an active on-line party available for communica- 
tion using the disclosed point-to-point Internet protocol. 
Similarly, a second user operating the second process- 
es ing unit 22, upon connection to the Internet 24 through 
the a connection service provider, is processed by the 
connection server 26 to be established in the database 
34 as an active on-line party. 
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[0026] The connection server 26 may use the time 
stamps to update the status of each processing unit; for 
example, after 2 hours, so that the on-line status infor- 
mation stored in the database 34 is relatively current. 
Other predetermined time periods, such as a default val- 5 
ue of 24 hours, may be configured by a systems oper- 
ator, 

[0027] The first user with the first processing unit 12 
initiates a call using, for example, a Send command and/ 
or a command to speeddial an N™ stored number, 
which may be labeled [SND] and[SPD] [N] ( respectively, 
by the input device 1 8 and/or the output device 20, such 
as shown in FIGS. 5-6. In response to either the Send 
or speeddial commands, the first processing unit 12 re- 
trieves from memory 16 a stored E-mail address of the 
callee corresponding to the N™ stored number. Alter- 
natively, the first user may directly enter the E-mail ad- 
dress of the callee. 

[0028] The first processing unit 1 2 then sends a query, 
including the E-mail address of the callee, to the con- 
nection server 26. The connection server 26 then 
searches the database 34 to determine whether the cal- 
lee is logged-in by finding any stored information corre- 
sponding to the callee's E-mail address indicating that 
the callee is active and on-line. If the callee is active and 
on-line, the connection server 26 then performs the pri- 
mary point-to-point Internet protocol; i.e. the IP address 
of the callee is retrieved from the database 34 and sent 
to the first processing unit 12. The first processing unit 
12 may then directly establish the point-to-point Internet 
communications with the callee using the IP address of 
the callee. 

[0029] If the callee is not on-line when the connection 
server 26 determines the callee's status, the connection 
server 26 sends an OFFLINE signal or message to the 
first processing unit 1 2. The first processing unit 12 may 
also display a message such as M Called Party Off-Line" 
to the first user. 

[0030] When a user logs off or goes off-line from the 
Internet 24, the connection server 26 updates the status 
of the user in the database 34; for example, by removing 
the user's information, or by flagging the user as being 
off-line. The connection server 26 may be instructed to 
update the user's information in the database 34 by an 
off-line message, such as a data packet, sent automat- 
ically from the processing unit of the user prior to being 
disconnected from the connection server 26. According- 
ly, an off-line user is effectively disabled from making 
and/or receiving point-to-point Internet communica- 
tions. 

[0031] As shown in FIGS. 2-4, the disclosed second- 
ary point-to-point Internet protocol may be used as an 
alternative to the primary point-to-point Internet protocol 
described above, for example, if the connection server 
26 is non-responsive, inoperative, and/or unable to per- 
form the primary point-to-point Internet protocol, as a 
non-responsive condition. Alternatively, the disclosed 
secondary point-to-point Internet protocol may be used 



independent of the primary point-to-point Internet pro- 
tocol. In the disclosed secondary point-to-point Internet 
protocol, the first processing unit 12 sends a <Connec- 
tRequest> message via E-mail over the Internet 24 to 
the mail server 28. The E-mail including the <Connec- 
tRequest> message may have, for example, the subject 

[*wp#XXXXXXXX#nnn.nnn.nnn.#emailAddr] 
where nnn.nnn.nnn.nnn. is the current (i.e. temporary 
or permanent) IP address of the first user, and 
XXXXXXXX is a session number, which may be unique 
and associated with the request of the first user to initiate 
point-to-point communication with the second user. 
[0032] As described above, the first processing unit 
12 may send the <ConnectRequest> message in re- 
sponse to an unsuccessful attempt to perform the pri- 
mary point-to-point Internet protocol. Alternatively, the 
first processing unit 12 may send the <Connec- 
tRequest> message in response to the first user initiat- 
ing a SEND command or the like. 
[0033] After the <ConnectRequest> message via E- 
mail is sent, the first processing unit 12 opens a socket 
and waits to detect a response from the second process- 
ing unit 22. A timeout timer, such as timer 32, may be 
set by the first processing unit 12, in a manner known 
in the art, to wait for a predetermined duration to receive 
a <ConnectOK> signal. The processor 14 of the first 
processing unit 12 may cause the output device 20 to 
output a Ring signal to the user, such as an audible ring- 
ing sound, about every 3 seconds. For example, the 
processor 14 may output a \wav file, which may be la- 
beled RING. WAV, which is processed by the output de- 
vice 20 to output an audible ringing sound. 
[0034] The mail server 28 then polls the second 
processing unit 22, for example, every 3-5 seconds, to 
deliver the E-mail. Generally, the second processing 
unit 22 checks the incoming lines, for example, at reg- 
ular intervals to wait for and to detect incoming E-mail 
from the mail server 28 through the Internet 24. 
[0035] Typically, for sending E-mail to users having 
associated processing units operatively connected to a 
host computer or server operating an Internet gateway, 
E-mail for a specific user may be sent over the Internet 
24 and directed to the permanent IP address or the 
SLIP/PPP account designation of the host computer, 
which then assigns a temporary IP address to the 
processing unit of the specified user for properly routing 
the E-mail. The E-mail signal may include a name or 
other designation such as a user name which identifies 
the specific user regardless of the processing unit as- 
signed to the user; that is, the host computer may track 
and store the specific device where a specific user is 
assigned or logged on, independent of the IP address 
system, and so the host computer may switch the E-mail 
signal to the device of the specific user. At that time, a 
temporary IP address may be generated or assigned to 
the specific user and device. 
[0036] Upon detecting and/or receiving the incoming 
E-mail signal from the first processing unit 12, the sec- 
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ond processing unit 22 may assign or may be assigned 
a temporary IP address. Therefore, the delivery of the 
E-mail through the Internet 24 provides the second 
processing unit 22 with a session number as well as IP 
addresses of both the first processing unit 12 and the 
second processing unit 22. 

[0037] Point-to-point communication may then be es- 
tablished by the processing unit 22 processing the E- 
mail signal to extract the <ConnectRequest> message, 
including the IP address of the first processing unit 12 
and the session number. The second processing unit 22 
may then open a socket and generate a <ConnectOK> 
response signal, which includes the temporary IP ad- 
dress of the second processing unit 22 as well as the 
session number of the first processing unit. 
[0038] The second processing unit 22 sends the 
<ConnectOK> signal directly over the Internet 24 to the 
IP address of the first processing unit 12 without 
processing by the mail server 28, and a timeout timer of 
the second processing unit 22 may be set to wait and 
detect a <Call> signal expected from the first processing 
unit 12. 

[0039] Realtime point-to-point communication of au- 
dio signals over the Internet 24, as well as video and 
voicemail, may thus be established and supported with- 
out requiring permanent IP addresses to be assigned to 
either of the users or processing units 12, 22. For the 
duration of the realtime point-to-point link, the relative 
permanence of the current IP addresses of the process- 
ing units 12, 22 is sufficient, whether the current IP ad- 
dresses were permanent (i.e. predetermined or preas- 
signed) or temporary (i.e. assigned upon initiation of the 
point-to-point communication). 
[0040] In the exemplary embodiment, a first user op- 
erating the first processing unit 12 is not required to be 
notified by the first processing unit 12 that an E-mail is 
being generated and sent to establish the point-to-point 
link with the second user at the second processing unit 
22. Similarly, the second user is not required to be no- 
tified by the second processing unit 22 that an E-mail 
has been received and/or a temporary IP address is as- 
sociated with the second processing unit 22. The 
processing units 12, 22 may perform the disclosed 
point-to-point Internet protocol automatically upon initi- 
ation of the point-to-point communication command by 
the first user without displaying the E-mail interactions 
to either user. Accordingly, the disclosed point-to-point 
Internet protocol may be transparent to the users. Alter- 
natively, either of the first and second users may re- 
ceive, for example, a brief message of "CONNECTION 
IN PROGRESS" or the like on a display of the respective 
output device of the processing units 12, 22. 
[0041] After the initiation of either the primary or the 
secondary point-to-point Internet protocols described 
above in conjunction with FIGS. 1 -2, the point-to-point 
communication link over the Internet 24 may be estab- 
lished as shown in FIGS. 3-4 in a manner known in the 
art. For example, referring to FIG. 3, upon receiving the 



<ConnectorOK> signal from the second processing unit 
22, the first processing unit 12 extracts the IP address 
of the second processing unit 22 and the session 
number, and the session number sent from the second 

5 processing unit 22 is then checked with the session 
number originally sent from the first processing unit 12 
in the <ConnectRequest> message as E-mail. If the 
session numbers sent and received by the processing 
unit 12 match, then the first processing unit 12 sends a 

10 <Cali> signal directly over the Internet 24 to the second 
processing unit 22; i.e. using the IP address of the sec- 
ond processing unit 22 provided to the first processing 
unit 12 in the <ConnectOK> signal. 
[0042] Upon receiving the <Call> signal, the second 

*5 processing unit 22 may then begin a ring sequence, for 
example, by indicating or annunciating to the second us- 
er that an incoming call is being received. For example, 
the word "CALL" may be displayed on the output device 
of the second processing unit 22. The second user may 

20 then activate the second processing unit 22 to receive 
the incoming call. 

[0043] Referring to FIG. 4, after the second process- 
ing unit 22 receives the incoming call, realtime audio 
and/or video conversations may be conducted in a man- 

25 ner known in the art between the first and second users 
through the Internet 24, for example, by compressed 
digital audio signals. Each of the processing units 12, 
22 also display to each respective user the words "IN 
USE" to indicate that the point-to-point communication 

30 link is established and audio or video signals are being 
transmitted. 

[0044] In addition, either user may terminate the 
point-to-point communication link by, for example, acti- 
vating a termination command, such as by activating an 

35 [END] button or icon on a respective processing unit, 
causing the respective processing unit to send an 
<End> signal which causes both processing units to ter- 
minate the respective sockets, as well as to perform oth- 
er cleanup commands and functions known in the art. 

40 [0045] FIGS. 5-6 illustrate examples of display 
screens 36 which may be output by a respective output 
device of each processing unit 12, 22 of FIGS. 1-4 for 
providing the disclosed point-to-point Internet protocol 
and system 10. Such display screens may be displayed 

^5 on a display of a personal computer (PC) or a PDA in a 
manner known in the art. 

[0046] As shown in FIG. 5, a first display screen 36 
includes a status area 38 for indicating, for example, a 
called user by name and/or by IP address or telephone 

50 number; a current function such as C2; a current time; 
a current operating status such as "IN USE", and other 
control icons such as a down arrow icon 40 for scrolling 
down a list of parties on a current conference line. The 
operating status may include such annunciators as "IN 

55 USE," "IDLE," "BUSY," "NO ANSWER," "OFFLINE," 
"CALL," "DIALING," "MESSAGES," and "SPEEDDIAL." 
[0047] Other areas of the display screen 36 may in- 
clude activation areas or icons for actuating commands 
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or entering data. For example, the display screen 36 
may include a set of icons 42 arranged in columns and 
rows including digits 0-9 and commands such as END, 
SND, HLD, etc. For example, the END and SND com- 
mands may be initiated as described above, and the 
HLD icon 44 may be actuated to place a current line on 
hold. Such icons may also be configured to substantially 
simulate a telephone handset or a cellular telephone in- 
terface to facilitate ease of use, as well as to simulate 
function keys of a keyboard. For example, icons labeled 
L1 -L4 may be mapped to function keys F1 -F4 on stand- 
ard PC keyboards, and icons C1 -C3 may be mapped to 
perform as combinations of function keys, such as 
CTRL-F1 , CTRL-F2, and CTRL-F3, respectively. In ad- 
dition, the icons labeled L1-L4 and C1-C3 may include 
circular regions which may simulate light emitting diodes 
(LEDs) which indicate that the function or element rep- 
resented by the respective icon is active or being per- 
formed. 

[0048] Icons L1-L4 may represent each of 4 lines 
available to the caller, and icons C1-C3 may represent 
conference calls using at least one line to connect, for 
example, two or more parties in a conference call. The 
icons L1 - L4 and C1 -C3 may indicate the activity of each 
respective line or conference tine. For example, as illus- 
trated in FIG. 5, icons L1-L2 may have lightly shaded or 
colored circles, such as a green circle, indicating that 
each of lines 1 and 2 are in use, while icons L3-L4 may 
have darkly shaded or color circles, such as a red or 
black circle, indicating that each of lines 3 and 4 are not 
in use. Similarly, the lightly shaded circle of the icon la- 
beled C2 indicates that the function corresponding to C2 
is active, as additionally indicated in the status are 38, 
while darkly shaded circles of icons labeled C1 and C3 
indicate that such corresponding functions are not ac- 
tive. 

[0049] The icons 42 are used in conjunction with the 
status area 38. For example, using a mouse for input, a 
line that is in use, as indicated by the tightly colored cir- 
cle of the icon, may be activated to indicate a party's 
name by clicking a right mouse button for 5 seconds u ntil 
another mouse click is actuated or the [ESC] key or icon 
is actuated. Thus, the user may switch between multiple 
calls in progress on respective lines. 
[0050] Using the icons as well as an input device such 
as a mouse, a user may enter the name or alias or IP 
address, if known, of a party to be called by either man- 
ually entering the name, by using the speeddial feature, 
or by double clicking on an entry in a directory stored in 
the memory, such as the memory 1 6 of the first process- 
ing unit 12, where the directory entries may be scrolled 
using the status area 38 and the down arrow icon 40. 
[0051] Once a called party is listed in the status area 
38 as being active on a line, the user may transfer the 
called party to another line or a conference line by click- 
ing and dragging the status area 38, which is represent- 
ed by a reduced icon 46. Dragging the reduced icon 46 
to any one of line icons L1 -L4 transfers the called party 



in use to the selected line, and dragging the reduced 
icon 46 to any one of conference line icons C1 -C3 adds 
the called party to the selected conference call. 
[0052] Other features may be supported, such as 

5 icons 48-52, where icon 48 corresponds to, for example, 
an ALT-X command to exit the communication facility of 
a processing unit, and icon 50 corresponds to, for ex- 
ample, an ALT-M command to minimize or maximize the 
display screen 36 by the output device of the processing 

io unit. Icon 52 corresponds to an OPEN command, which 
may, for example, correspond to pressing the O key on 
a keyboard, to expand or contract the display screen 36 
to represent the opening and closing of a cellular tele- 
phone. An "opened" configuration is shown in FIG. 5, 

15 and a "closed" configuration is shown in FIG. 6. In the 
"opened" configuration, additional features such as out- 
put volume (VOL) controls, input microphone (MIC) con- 
trols, waveform (WAV) sound controls, etc. 
[0053] The use of display screens such as those 

20 shown in FIGS. 5-6 provided flexibility in implementing 
various features available to the user. It is to be under- 
stood that additional features such as those known in 
the art may be supported by the processing units 1 2, 22. 
[0054] Alternatively, it is to be understood that one 

25 skilled in the art may implement the processing units 12, 
22 to have the features of the display screens in FIGS. 
5-6 in hardware; i.e. a wired telephone or wireless cel- 
lular telephone may include various keys, LEDs, liquid 
crystal displays (LCDs), and touchscreen actuators cor- 

30 responding to the icons and features shown in FIGS. 
5-6. In addition, a PC may have the keys of a keyboard 
and mouse mapped to the icons and features shown in 
FIGS. 5-6. 

[0055] Referring to FIG. 7, the disclosed point-to- 

35 point Internet protocol and system 1 0 is illustrated. First 
processing unit 12 initiates the point-to-point Internet 
protocol in step 56 by sending a query from the first 
processing unit 12 to the connection server 26. If con- 
nection server 26 is operative to perform the point-to- 

40 point Internet protocol, in step 58, first processing unit 
12 receives an on-line status signal from the connection 
server 26, such signal may include the IP address of the 
callee or a "Callee Off-Line" message. Next, first 
processing unit 12 performs the primary point-to-point 

45 Internet protocol in step 60, which may include receiv- 
ing, at the first processing unit 12, the IP address of the 
callee if the callee is active and on-line. Alternatively, 
processing unit 60 may initiate and perform the second- 
ary point-to-point Internet protocol in step 62, if the 

so called party is not active and/or on-line. 

[0056] Referring to FIG. 8, in conjunction with FIGS. 
1 and 3-4, the disclosed point-to-point Internet protocol 
and system 1 0 is illustrated. Connection server 26 starts 
the point-to-point Internet protocol, in step 64, and 

55 timestamps and stores E-mail and IP addresses of 
logged-in users and processing units in the database 34 
in step 66. Connection server 26 receives a query from 
a first processing unit 1 2 in step 68 to determine whether 
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a second user or second processing unit 22 is logged- 
in to the Internet 24, with the second user being speci- 
fied, for example, by an E-mail address. Connection 
server 26 retrieves the IP address of the specified user 
from the database 34 in step 70, if the specified user is 
logged-in to the Internet, and sends the retrieved IP ad- 
dress to the first processing unit 1 2 in step 72 to enable 
first processing unit 12 to establish point-to-point com- 
munications with the specified second user 
[0057] The disclosed secondary point-to-point inter- 
net protocol operates as shown in FIG. 9. First process- 
ing unit 12 generates an E-mail signal, including a ses- 
sion number and a first IP address corresponding to a 
first processing unit in step 76. First processing unit 12 
transmits the E-mail signal as a <ConnectRequest> sig- 
nal to the Internet 24 in step 78. The E-mail signal is 
delivered through the Internet 24 using a mail server 28 
to the second processing unit 22 in step 80. Second 
processing unit 22 extracts the session number and the 
first IP address from the E-mail signal in step 82 and 
transmits or sends the session number and a second IP 
address corresponding to the second processing unit 
22, back to the first processing unit 12 through the In- 
ternet 24, in step 84. First processing unit 12 verifies the 
session number received from the second processing 
unit 22 in step 86, and establishes a point-to-point Inter- 
net communication link between the first processing unit 
12 and second processing unit 22 using the first and 
second IP addresses in step 88. 
[0058] While the disclosed point-to-point Internet pro- 
tocols and system have been particularly shown and de- 
scribed with reference to the preferred embodiments, it 
is understood by those skilled in the art that various 
modifications in form and detail may be made therein 
without departing from the scope and spirit of the inven- 
tion. Accordingly, modifications such as those suggest- 
ed above, but not limited thereto, are to be considered 
within the scope of the invention. 



Claims 

1. A method for establishing point-to-point Internet 
communication between a plurality of processing 
units characterized by the steps: 

a) transmitting an E-mai! signal, including a first 
IP address assigned to a first processing unit 
(12); 

b) processing the E-mail signal through the In- 
ternet to deliver the E-mail signal to a second 
processing unit (22); and 

c) transmitting a second IP address to the first 
processing unit for establishing a point-to-point 
communication link between the first and sec- 
ond processing units through the Internet. 

2. The method of claim 1 , further characterized by: 



a1) generating the E-mail signal from the first 
IP address corresponding to the first process- 
ing unit before the step (a) of transmitting the 
E-mail signal. 

5 

3. The method of claim 1 , further characterized by: 

a1 ) generating the E-mail signal from a session 
number before the step (a) of transmitting the 
10 E-mail signal. 

4. The method of claim 1 , characterized in that the 

step of processing the E-mail signal further com- 
prises the step of: 

15 

b1) processing the E-mail signal using a mail 
server operatively connected to the second 
processing unit. 

20 5. The method of claim 1 , further characterized by: 

b1) generating a connection signal (CONNEC- 
TOK) including the second IP address at the 
second processing unit before the step (c) of 
25 transmitting the second IP address to the first 

processing unit, and 

wherein the step (c) of transmitting the second IP 
address includes the step of transmitting the con- 
so nection signal from the second processing unit to 
the first processing unit. 

6. A system for enabling point-to-point communica- 
tions between a first and a second processing unit 
35 over the Internet, characterized by: 

a) means for transmitting from the first process- 
ing unit (1 2) to the Internet an E-mail signal, in- 
cluding a first IP address assigned to the first 

40 processing unit; 

b) means (28) for processing the E-mail signal 
through the Internet to deliver the E-mail signal 
to the second processing (22) unit; and 

c) means for transmitting a second IP address 
45 to the first processing unit for establishing a 

point-to-point communication link between the 
first and second processing units through the 
Internet. 

so 7. The system of claim 6 comprising a server which is 
characterized by: 

a processor; 

a memory operatively coupled to the processor; 
55 a network interface logic operatively coupled to 

the processor and the memory and configured 
to connect the server to a computer network; 
and 
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mail processing logic responsive to an E-mail 
signal from the first processing unit and config- 
ured to provide the E-mail signal to the second 
processing unit, the E-mail signal comprising 
the network protocol address of the first 
processing unit 

8. The system of claim 6, further characterized by: 

b1) means for generating a connection signal 
(CONNECTOK) including the second IP ad- 
dress in the second processing unit, and for 
transmitting the connection signal from the sec- 
ond processing unit to the first processing unit. 

9. The system of claim 6, wherein the first processing 
unit comprises a processor for executing the point- 
to-point Internet protocol, characterized by means 
for generating an E-mail signal, including a first IP 
address, and by means for transmitting the E-mail 
signal through the Internet to the second processing 
unit for establishing a point-to-point communication 
link to the first processing unit. 

10. The system of claim 9, characterized in that the 

processor is adapted to generate the E-mail signal 
from the first IP address corresponding to the first 
processing unit. 

1 1 . The apparatus of claim 9, characterized in that the 

processor is adapted to wait to detect a response 
from the second processing unit. 

12. The system according to one of the claims 6-11, 
characterized in that the first IP address is dynam- 
ically assigned to the first processing unit. 

13. The system according to one of the claims 6-12, 
comprising a mail server (28) for processing the E- 
mail signal through the Internet to deliver the E-mail 
to the second processing unit (22) for establishing 
a point-to-point communication link between the 
first and second processing unit through the Inter- 
net. 

14. The system of claim 13, wherein the second 
processing unit comprises a processor adapted for 
receiving the E-mail signal from the mail server and 
for generating a connection signal (CONNECTOK) 
including a second IP address and for transmitting 
the connection signal to the first processing unit for 
establishing the point-to-point communication link 
to the first processing unit. 



puter readable program code, comprising: 

a) program code for transmitting an E-mail sig- 
nal including a first IP address assigned to a 

5 first processing unit (12); 

b) program code for processing the E-mail sig- 
nal through the Internet to deliver the E-mail 
signal to a second processing unit (22); 

c) program code for transmitting a second IP 
10 address to the first processing unit; and 

d) program code for establishing in response to 
receiving the second IP address in the first 
processing unit a point-to-point communication 
link between the first and second processing 

*5 units through the Internet. 

16. The computer program product of claim 1 5, further 
characterized by: 

20 b1 ) program code for generating a connection 

signal (CONNECTOK) including the second IP 
address at the second processing unit; and 
d) program code for transmitting the connec- 
tion signal from the second processing unit to 

25 the first processing unit. 

17. The computer program product of claim 1 5, further 
comprising in a memory (16) of the first processing 
unit: 

30 

program code for performing a point-to-point 
Internet protocol; 

program code for generating an E-mail signal, 
including a first IP address; and 

35 program code for use of a mail server (28) for 

processing the E-mail signal through the Inter- 
net to deliver the E-mail to the second process- 
ing unit for establishing a point-to-point com- 
munication link between the first and second 

40 processing unit. 

18. The computer program product of claim 15, further 
comprising in a memory of the second processing 
unit: 

45 

second program code for performing a point-to- 
point Internet protocol; program code for re- 
ceiving the E-mail signal from a mail server; and 
program code for generating a connection sig- 
so nal including a second IP address for establish- 

ing the point-to-point communication link to the 
first processing unit. 



15. A computer program product for establishing point- 55 
to-point Internet communication between a plurality 
of processing units, the computer program product 
having a computer usable medium containing com- 
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